草庐IT

c++ - QMap 和 std::unique_ptr

全部标签

c++ - __sync_val_compare_and_swap 与 __sync_bool_compare_and_swap

我一直在思考这两个函数的返回值。__sync_bool_compare_and_swap函数的返回值似乎有明显的好处,即我可以用它来判断交换操作是否发生。但是,我看不到__sync_val_compare_and_swap的返回值的良好用途。首先,让我们有一个函数签名供引用(来自GCC文档减去varargs):type__sync_val_compare_and_swap(type*ptr,typeoldvaltypenewval);我看到的问题是__sync_val_compare_and_swap的返回值是*ptr的旧值。准确地说,这是在设置了适当的内存屏障后,此函数的实现所看到的

c++ - boost::shared_ptr,ctor 中的一个原子递增,但 dtor 中的两个原子递减?

我正在单步执行boost::shared_ptr的源代码,并且在构造时引用计数器调用一次原子增量。但是,在销毁时我看到原子递减被调用了两次,连接到弱引用?但是,这怎么行呢?在构建时递增一次,在销毁时递减两次,一次在release()中,一次在weak_release()中? 最佳答案 shared_ptr必须维护两个引用计数。一个用于共享实例,一个用于可能通过weak_ptr引用。有了这个,weak_ptr能够增加shared_ptr中的弱引用计数并保持shared_ptr事件(即使在分配的对象被释放之后)以确定从weak_ptr到

c++ - cblas_dgemv 的意外结果

我有一个关于cblas_dgemv的问题。我试图了解它是如何工作的。我可能做错了什么。我有一个数组Matrix,然后我尝试读取该矩阵RowMajor和ColumnMajor。我在RowMajorCase中得到了预期的结果;[6,2,4,6]'。但是对于ColMajor,我得到[-7,3,0,5]'而答案应该是[6,3,2,3]'这是我的代码。我正在使用英特尔MKL。#include#include#include#include#defineNCols5#defineNrows4doubleA[]={8,4,7,3,5,1,1,3,2,1,2,3,2,0,1,1,2,3,4,1};do

c++ - 在没有 C++11 的情况下使用 unique_ptr

这个问题在这里已经有了答案:unique_ptrboostequivalent?(5个答案)关闭7年前。我想将指向d的指针从一个容器传递到下一个容器。在任何时候都不会有超过一个指针的所有者(或d本身)。我希望当最后一个指针超出范围时,自动调用deleted。在C++11中,我将使用unique_ptr来完成此操作。但是,唉,我不能使用C++11。C++中最好的等价物是什么?升压就好了或者,如果没有,处理此问题的适当方法是什么?

c++ - std::string::reserve() 和 std::string::clear() 难题

这道题从一段代码开始,只是因为我觉得这样更容易看出我在追求什么:/*static*/voidUrl::Split(std::list&url,conststd::string&stringUrl){std::stringcollector;collector.reserve(stringUrl.length());for(autoc:stringUrl){if(PathSeparator==c){url.push_back(collector);collector.clear();//Sabotagesmyoptimizationwithreserve()above!}else{col

c++ - {} 是传递给需要迭代器(代表某个容器的 std::end() )的函数的有效参数吗?

在boostdirectory_iteratorexample-howtolistdirectoryfilesnotrecursive(参见thisanswer)中是示例代码#include#include#include...usingnamespaceboost::filesystem;for(auto&entry:boost::make_iterator_range(directory_iterator(p),{})){std::cout(p是boost::filesystem::path类型。)在查看documentationformake_iterator_range时,我认

c++ - 使用 C 头文件错误编译 Cython

所以我正在尝试用Cython包装一些C代码。我阅读了有关执行此操作的应用Cython教程(1、2),但这些教程并没有说明如何用Cython包装代码后如何编译代码,因此我有一个错误说它可以'找不到我的C代码。首先,我的cython脚本(“calcRMSD.pyx”):importnumpyasnpcimportnumpyasnpcdefexternfrom"rsmd.h":doublermsd(intn,double*x,double*y)#restofthecodeommited我试图包装的C代码(“rmsd.h”):#include#include#include#includeex

c++ - 为异质宽度的整数编写 std::min/std::max

我的C++程序使用不同宽度的无符号整数来表示对可以表示的数据的约束。例如,我有一个大小为uint64_t的文件,我希望使用大小为size_t的缓冲区以block的形式读取它。block是缓冲区大小和(剩余)文件大小中较小的一个:uint64_tfile_size=...;size_tbuffer_size=...;size_tchunk_size=std::min(buffer_size,file_size);但这失败了,因为std::min要求两个参数具有相同的类型,所以我必须向上转换然后再向下转换:size_tchunk_size=\static_cast(std::min(sta

当我用单引号括起一个字符串时,C++ std::cout 打印奇怪的字符

这个问题在这里已经有了答案:WhatdosinglequotesdoinC++whenusedonmultiplecharacters?(5个答案)关闭7年前。当我尝试std::cout我得到了11296,我知道我应该用","把它括起来,但为什么我会得到号码?

c++ - 使用带有参数包扩展和附加值的静态存储持续时间初始化 std::array

在询问时anotherquestion最近,在用参数包扩展后跟另一个元素初始化std::array时,我偶然发现了GCC的一些奇怪行为。我已经与Jarod42简要讨论过这个问题inthecommentsthere但我认为最好将其作为一个新问题提出。例如,考虑下面的代码,它应该提供一个实用程序make_array函数,该函数接受任意数量的参数并将它们std::forward发送到std::array初始化。前导标记参数选择数组是否应以默认构造的T(通过std::true_type选择)或不(通过std::选择)终止false_type).然后我创建一个整数数组,一次使用静态,一次使用自动